<script setup>
import { Edit, Delete } from '@element-plus/icons-vue'
import { articleDelChannelService, articleGetChannelService } from '@/api/article'
import { ref } from 'vue'
import ChannelEdit from '@/views/article/components/ChannelEdit.vue'
import { ElMessage, ElMessageBox } from 'element-plus'
const channelList = ref([])
const dialog = ref()

const loading = ref(false)

const getChannelList = async () => {
    loading.value = true
    const res = await articleGetChannelService()
    channelList.value = res.data.data
    // channelList.value = []
    loading.value = false
    console.log(res.data)
}

getChannelList()

const onDelChannel = async (id) => {
    await ElMessageBox.confirm('你确认要删除此文章分类吗？', '温馨提示', {
        type: 'warning',
        confirmButtonText: '确认',
        cancelButtonText: '取消'
    })
    await articleDelChannelService(id)
    ElMessage.success('删除成功')
    getChannelList()
}
const onEditChannel = (row) => {
    console.log(row)
    dialog.value.open(row)
}
const onAddChannel = () => {
    dialog.value.open({})
}
const onSuccess = () => {
    getChannelList()
}
</script>
<template>
    <page-container title="文章分类">
        <template #extra>
            <el-button type="primary" @click="onAddChannel">添加分类</el-button>
        </template>
        <!--主体部分，是表格-->
        <el-table v-loading="loading" :data="channelList" style="width: 100%">
            <el-table-column type="index" label="序号" width="100" />
            <el-table-column prop="cate_name" label="分类名称" />
            <el-table-column prop="cate_alias" label="分类别名" />
            <el-table-column label="操作">
                <template #default="{ row, $index}">
                    <el-button
                        :icon="Edit"
                        circle
                        plain
                        type="primary"
                        @click="onEditChannel(row, $index)"
                    ></el-button>
                    <el-button
                        :icon="Delete"
                        circle
                        plain
                        type="danger"
                        @click="onDelChannel(row.id)"
                    ></el-button>
                </template>
            </el-table-column>
            <template #empty>
                <el-empty description="没有数据"></el-empty>
            </template>
        </el-table>
        <channel-edit ref="dialog" @success="onSuccess"></channel-edit>
    </page-container>
</template>
<style lang="scss" scoped>

</style>